<template>
    <div>
  <!-- 一条文章单元格 -->
  <van-cell>
    <!-- 标题区域的插槽 -->
    <template #title>
      <div class="title-box">
        <!-- 标题 -->
        <span>{{  artObj.title }}</span>
        <!-- 单图 -->
        <img v-if="artObj.cover.type===1" class="thumb"  alt="" v-lazy="artObj.cover.images[0]">
        <!-- <van-image v-if="artObj.cover.type===1" class="thumb" :src="artObj.cover.images[0]"> -->
  <!-- <template v-slot:error>加载失败</template> -->
<!-- </van-image> -->
      </div>
      <!-- 三图 -->
      <div class="thumb-box" v-if="artObj.cover.type>1" >
        <img v-for=" (imgUrl,index) in artObj.cover.images " :key="index" class="thumb"  alt="" v-lazy="imgUrl">
        <!-- <van-image v-for="(imgUrl,index) in artObj.cover.images" :key="index" class="thumb" :src="imgUrl">
  <template v-slot:error>加载失败</template>
</van-image> -->
      </div>
    </template>
    <!-- label 区域的插槽 -->
    <template #label>
      <div class="label-box">
        <div>
          <span>{{ artObj.aut_name }}</span>
          <span>{{ artObj.comm_count }}</span>
          <span>{{ formatTime(artObj.pubdate )}}</span>
        </div>
        <!-- 反馈按钮 -->
        <van-icon name="cross" @click.stop="show=true"  v-if="isShow"/>
      </div>
    </template>
  </van-cell>
  <!-- 反馈面板 -->
  <van-action-sheet v-model="show" :actions="actions" @select="onSelect" @cancel="cancelFn" @close="closeFn"  get-container="body" :cancel-text="bottomText"/>
</div>
</template>

<script>
// 监听点击事件，区分用户点击的是哪一个
// 切换 action面板的数据
// :cancel-text="bottomText" 设置变量，onSelect中，把变量值换成’返回‘
// 目标3：点击底部按钮，要区分判断
// 1.标签@cancel取消事件和事件方法
// 2.在标签使用bottomText的值，判断用户点击的是否为’返回
// 换数据源actions:firstActions
// bottom文字改为‘取消’
import { timeAgo } from '@/utils/date'
import { firstActions, secondActions } from '@/api/report'
export default {
  props: {
    artObj: Object, // 文章对象
    isShow: {
      type: Boolean,
      default: true // 例如首页的地方不再去动，首页肯定没传isShow,所以首页需要显示
    }
  },
  data () {
    return {
      show: false, // 反馈面板显示或隐藏
      actions: firstActions, // 反馈面板选项数组（套对象）
      bottomText: '取消'
    }
  },
  methods: {
    formatTime: timeAgo, // 函数体是timeAgo
    onSelect (action, item) {
    //   console.log(action) // {name:'反馈垃圾内容'}
    //   console.log(item) // 索引值
      // 默认情况下点击选项时不会自动收起
      // 可以通过 close-on-click-action 属性开启自动收起
    //   this.show = false
      if (action.name === '反馈垃圾内容') {
        this.actions = secondActions
        this.bottomText = '返回'
      } else if (action.name === '不感兴趣') {
        this.$emit('dislikeEv', this.artObj.art_id)
        this.show = false // 无论反馈成功或失败，直接让反馈面板消失
      } else {
        this.$emit('reportEV', this.artObj.art_id, action.value)
        this.show = false // 关闭-下面的cancel 会帮你把反馈选项切回来
      }
    },
    // 底部返回按钮
    cancelFn () {
      if (this.bottomText === '返回') {
        this.show = true // 强制让他回来
        this.actions = firstActions
        this.bottomText = '取消'
      }
    },
    // 关闭面板触发事件
    closeFn () {
      this.actions = firstActions
      this.bottomText = '取消'
    }
  }
}

</script>

<style scoped lang="less">
/* 标题样式 */
.title-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* label描述样式 */
.label-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* 文章信息span */
.label-box span {
  margin: 0 3px;
  &:first-child {
    margin-left: 0;
  }
}
/* 图片的样式, 矩形黄金比例：0.618 */
.thumb {
  width: 113px;
  height: 70px;
  background-color: #f8f8f8;
  object-fit: cover;
}

/* 三图, 图片容器 */
.thumb-box {
  display: flex;
  justify-content: space-between;
}
</style>
